<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    <button>点击</button>
    <script>
        //bind() 绑定 捆绑的意思
        // var o = {
        //     name: 'andy'
        // }
        // function fn(a, b) {
        //     console.log(this);
        //     console.log(a + b);
        // }
        // var f = fn.bind(o, 1, 3);
        // f();
        // //不会调用原来的函数 可以改变原来函数内部的this指向
        // // 返回的是原函数改变this之后产生的新函数
        // var btn = document.querySelector('button');
        // btn.onclick = function () {
        //     this.disabled = true; //this 指向btn
        //     setTimeout(function () {
        //         this.disabled = false;  //this 指向 btn
        //     }.bind(this), 2000) //this指向btn
        // }
        var btns = document.querySelectorAll('button');
        for (let i = 0; i < btns.length; i++) {
            btns[i].onclick = function () {
                this.disabled = true;
                setTimeout(function () {
                    this.disabled = false;
                }.bind(this), 2000)
            }
        }
    </script>
</body>

</html>